// 设置文件
import setting from '@/setting.js';

export default {
  namespaced: true,
  state: {
    // 是否开启页面过度动画
    active: setting.transition.active,
  },
  actions: {
    /**
     * @description 设置开启状态
     * @param {Object} state vuex state
     * @param {Boolean} active 新的状态
     */
    set({ state, dispatch }, active) {
      // eslint-disable-next-line no-async-promise-executor
      return new Promise(async (resolve) => {
        // store 赋值
        state.active = active;
        // 持久化
        await dispatch(
          'vxadmin/db/set',
          {
            dbName: 'sys',
            path: 'transition.active',
            value: state.active,
            user: true,
          },
          { root: true },
        );
        // end
        resolve();
      });
    },
    /**
     * 从数据库读取页面过渡动画设置
     * @param {Object} state vuex state
     */
    load({ state, dispatch }) {
      // eslint-disable-next-line no-async-promise-executor
      return new Promise(async (resolve) => {
        // store 赋值
        state.active = await dispatch(
          'vxadmin/db/get',
          {
            dbName: 'sys',
            path: 'transition.active',
            defaultValue: setting.transition.active,
            user: true,
          },
          { root: true },
        );
        // end
        resolve();
      });
    },
  },
};
